Browser Developer Tools এর মাধ্যমে Chart Debugging

Web Development - অ্যাঙ্গুলার গুগল চার্ট (Angular Google Charts) - Testing এবং Debugging (টেস্টিং এবং ডিবাগিং) |
2
2

Browser Developer Tools (DevTools) একটি গুরুত্বপূর্ণ টুল যা ডেভেলপারদের তাদের ওয়েব পেজ বা অ্যাপ্লিকেশনের কোড ডিবাগ, অপটিমাইজ, এবং অ্যানালাইজ করতে সহায়তা করে। যখন আপনি Google Charts বা অন্য কোনো চার্ট লাইব্রেরি ব্যবহার করছেন, তখন DevTools ব্যবহার করে আপনি আপনার চার্টের সমস্যা চিহ্নিত করতে, পারফরম্যান্স অপটিমাইজ করতে এবং সঠিকভাবে ডেটা রেন্ডার হচ্ছে কিনা তা নিশ্চিত করতে পারবেন।

এই গাইডে আমরা দেখব কীভাবে Browser Developer Tools ব্যবহার করে Google Charts এর ডিবাগিং করা যায়।


DevTools ব্যবহার করে Chart Debugging করার স্টেপস

1. Google Charts এর জন্য Console Logs ব্যবহার করা

Console Logs ব্যবহার করা খুবই গুরুত্বপূর্ণ, কারণ এটি কোডের মধ্যে যেকোনো সমস্যা চিহ্নিত করতে সহায়তা করে। আপনার চার্টের ডেটা এবং অপশনগুলি চেক করতে আপনি console.log() ব্যবহার করতে পারেন।

console.log('Chart Data:', this.chartData);
console.log('Chart Options:', this.chartOptions);

এই লোগ গুলি আপনাকে চার্টের ডেটা এবং কাস্টমাইজেশন অপশন পরীক্ষা করতে সহায়তা করবে।

2. Browser Developer Tools চালু করা

প্রথমত, আপনাকে Developer Tools চালু করতে হবে। এটি চালু করতে, ব্রাউজারের কোনো পেজে ডান-ক্লিক করে Inspect (বা Inspect Element) নির্বাচন করুন অথবা F12 বা Ctrl + Shift + I কী প্রেস করুন।

এটি Chrome DevTools, Firefox Developer Tools, বা আপনার ব্যবহৃত অন্য ব্রাউজারের Developer Tools প্যানেল খুলবে।

3. Console Tab এর ব্যবহার

Console ট্যাবটি আপনাকে আপনার JavaScript কোডের লোগগুলো দেখাবে। যদি আপনি console.log() ব্যবহার করে থাকেন, তবে চার্টের ডেটা, অপশন এবং অন্যান্য গুরুত্বপূর্ণ তথ্য এখানে প্রদর্শিত হবে। উদাহরণস্বরূপ:

console.log('Google Chart Data:', this.chartData);

Console ট্যাবের মাধ্যমে আপনি নিশ্চিত হতে পারবেন যে ডেটা সঠিকভাবে পাস হচ্ছে এবং চার্টে প্রদর্শিত হচ্ছে।

4. Elements Tab এবং DOM Inspection

Elements ট্যাবটি দিয়ে আপনি HTML ডকুমেন্টের DOM (Document Object Model) পরীক্ষা করতে পারেন। এখানে আপনি দেখতে পাবেন যে আপনার চার্টটি কিভাবে রেন্ডার হচ্ছে। আপনি যেকোনো HTML এলিমেন্টের উপর ক্লিক করে তার স্টাইল, ক্লাস, এবং অন্যান্য বৈশিষ্ট্য পরীক্ষা করতে পারবেন।

Elements ট্যাবের মাধ্যমে আপনি এলিমেন্ট খুঁজে পেতে পারেন এবং চেক করতে পারেন:

  • চার্টের আয়তন (width, height)
  • চার্টের কন্টেন্ট এবং ডেটা
  • সিএসএস স্টাইলিং
  • লেজেন্ড এবং টাইটেল

5. Network Tab ব্যবহার করা

Network ট্যাব ব্যবহার করে আপনি যেকোনো নেটওয়ার্ক রিকোয়েস্ট (যেমন API কল, ডেটা ফেচিং) ট্র্যাক করতে পারেন। এটি আপনাকে বুঝতে সাহায্য করবে যে ডেটা ঠিকমতো সার্ভার থেকে আসছে কিনা এবং কোনো সমস্যা হচ্ছে কিনা।

  • XHR (XMLHttpRequest) অথবা Fetch রিকোয়েস্টগুলো দেখতে পাবেন যেগুলি API থেকে ডেটা ফেচ করতে ব্যবহৃত হয়।
  • Status Code: API রিকোয়েস্ট সফলভাবে সম্পন্ন হচ্ছে কিনা তা দেখতে পাবেন (যেমন 200, 404, 500 ইত্যাদি)।
  • Response Data: API রেসপন্স ডেটা দেখুন যা চার্টের জন্য ব্যবহৃত হচ্ছে।

6. Performance Tab এবং Rendering Issues

Performance ট্যাব আপনাকে চার্টের রেন্ডারিং পারফরম্যান্স ট্র্যাক করতে সাহায্য করবে। এটি দেখতে পাবেন:

  • চার্ট রেন্ডার হওয়ার জন্য কত সময় লাগছে।
  • কোনো রেন্ডারিং লেগ বা সমস্যা হচ্ছে কিনা তা চিহ্নিত করতে সাহায্য করবে।

বিশেষ করে যখন বড় ডেটা সেট ব্যবহৃত হয়, তখন পারফরম্যান্স সমস্যা দেখা দিতে পারে। আপনি এভাবে পারফরম্যান্স সমস্যা সমাধান করতে পারবেন।

7. Application Tab এবং Service Worker

Application ট্যাবটি দিয়ে আপনি Service Worker এবং IndexedDB (যদি আপনি অ্যাপ্লিকেশনের জন্য ক্যাশিং ব্যবহার করেন) পরীক্ষা করতে পারবেন। এটি আপনাকে চার্টের ডেটা যদি ক্যাশে করা থাকে তা দেখতে সাহায্য করবে।

  • Service Worker: আপনি নিশ্চিত হতে পারবেন যে আপনার অ্যাপ্লিকেশন সঠিকভাবে ব্যাকগ্রাউন্ড ডেটা ফেচ করছে এবং ডেটা সিঙ্ক হচ্ছে কিনা।
  • IndexedDB: এই স্টোরেজের মাধ্যমে আপনি ব্রাউজারে ডেটা স্টোর এবং ক্যাশিং ট্র্যাক করতে পারবেন।

8. Sources Tab এবং JavaScript Debugging

Sources ট্যাবটি দিয়ে আপনি JavaScript কোড ডিবাগ করতে পারেন। যদি আপনার চার্টের ডেটা ঠিকমতো না আসছে, তবে আপনি এখানে আপনার স্ক্রিপ্টে ব্রেকপয়েন্ট সেট করতে পারেন এবং ডেটার স্টেপ বাই স্টেপ ট্র্যাকিং করতে পারেন।

  • Breakpoints: কোডের নির্দিষ্ট অংশে ব্রেকপয়েন্ট সেট করতে পারেন এবং সেখান থেকে কোড চালানোর সময় ভ্যালু চেক করতে পারবেন।
  • Call Stack: কোডের execution flow দেখতে পাবেন এবং যদি কোনো ফাংশন ভুলভাবে কল হয় বা কোনো সমস্যা হয় তবে তা চিহ্নিত করতে পারবেন।

9. Network Throttling and Testing Slow Connections

DevTools এ আপনি Network Throttling করতে পারেন যাতে আপনি ধীর গতির ইন্টারনেট সংযোগে আপনার চার্টের পারফরম্যান্স পরীক্ষা করতে পারেন। এটি নিশ্চিত করে যে, আপনার চার্ট অ্যাপ্লিকেশনটি ধীর সংযোগেও সঠিকভাবে কাজ করছে।

  • Disable Cache: আপনি Network ট্যাবের মধ্যে "Disable cache" অপশনটি চেক করতে পারেন যাতে আপনার ব্রাউজার ক্যাশিং না করে এবং প্রতি রিকোয়েস্টে ফ্রেশ ডেটা ফেচ করে।

চলমান উদাহরণ: Google Chart Debugging

এখন, আমরা একটি ছোট উদাহরণ দেব যেখানে Google Chart এর ডেটা এবং অপশন ডিবাগ করার জন্য console.log() ব্যবহার করা হবে।

app.component.ts (ডিবাগিং)

import { Component } from '@angular/core';

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
  title = 'Google Chart Debugging';

  chartType = 'PieChart'; // Chart Type
  chartData = [
    ['Task', 'Hours per Day'],
    ['Work', 8],
    ['Eat', 2],
    ['Commute', 2],
    ['Watch TV', 2],
    ['Sleep', 8]
  ]; // Chart Data

  chartOptions = {
    title: 'My Daily Activities', // Title
    pieHole: 0.4, // Doughnut Style
    width: 600, // Fixed width
    height: 400 // Fixed height
  };

  ngOnInit(): void {
    console.log('Chart Data:', this.chartData);
    console.log('Chart Options:', this.chartOptions);
  }
}

app.component.html (চালানো)

<h1>{{ title }}</h1>

<google-chart 
  [type]="chartType" 
  [data]="chartData" 
  [options]="chartOptions">
</google-chart>

Console Output:

DevTools Console ট্যাবে আপনি দেখতে পাবেন:

Chart Data: [['Task', 'Hours per Day'], ['Work', 8], ['Eat', 2], ['Commute', 2], ['Watch TV', 2], ['Sleep', 8]]
Chart Options: { title: 'My Daily Activities', pieHole: 0.4, width: 600, height: 400 }

এটি নিশ্চিত করবে যে আপনার ডেটা এবং অপশন সঠিকভাবে পাস হচ্ছে এবং আপনার Google Chart সঠিকভাবে রেন্ডার হচ্ছে।


সারাংশ

Browser Developer Tools ব্যবহার করে আপনি Google Charts এর ডিবাগিং করতে পারেন। Console Logs, Elements, Network, Performance, Sources, এবং Application ট্যাব ব্যবহার করে আপনি ডেটা এবং চার্টের রেন্ডারিং চেক করতে পারবেন। এছাড়া Network Throttling এবং Service Worker Debugging ব্যবহার করে আপনি ব্যাকগ্রাউন্ড ডেটা ফেচিং এবং সিস্টেমের অন্যান্য অংশের কার্যকারিতা পরীক্ষা করতে পারবেন।

Content added By
Promotion